# TMS320x2833x Direct Memory Access (DMA) Module

# Reference Guide

Literature Number: SPRUFB8 September 2007



# **Contents**

| Preta | асе      |                                                                                                                            | . 6 |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------|-----|
| 1     | Introdu  | ction                                                                                                                      | . 9 |
| 2     | Archite  | cture                                                                                                                      | 10  |
|       | 2.1      | Block Diagram                                                                                                              | 10  |
|       | 2.2      | Peripheral Interrupt Event Trigger Sources                                                                                 | 10  |
|       | 2.3      | DMA Bus                                                                                                                    | 12  |
| 3     | Pipeline | e Timing and Throughput                                                                                                    | 12  |
| 4     | CPU Ar   | bitration                                                                                                                  | 13  |
|       | 4.1      | For the External Memory Interface (XINTF) Zones                                                                            | 13  |
|       | 4.2      | For All Other Peripherals/Memories                                                                                         | 14  |
| 5     | Channe   | el Priority                                                                                                                | 14  |
|       | 5.1      | Round-Robin Mode                                                                                                           | 14  |
|       | 5.2      | Channel 1 High Priority Mode                                                                                               | 15  |
| 6     | Addres   | s Pointer and Transfer Control                                                                                             | 15  |
| 7     | ADC Sy   | /nc Feature                                                                                                                | 20  |
| 8     | ADC O    | verrun                                                                                                                     | 21  |
| 9     |          | er Descriptions                                                                                                            |     |
|       | 9.1      | DMA Control Register (DMACTRL) — EALLOW Protected                                                                          |     |
|       | 9.2      | Debug Control Register (DEBUGCTRL) — EALLOW Protected                                                                      |     |
|       | 9.3      | Revision Register (REVISION)                                                                                               |     |
|       | 9.4      | Priority Control Register 1 (PRIORITYCTRL1) — EALLOW Protected                                                             | 25  |
|       | 9.5      | Priority Status Register (PRIORITYSTAT)                                                                                    | 25  |
|       | 9.6      | Mode Register (MODE) — EALLOW Protected                                                                                    | 27  |
|       | 9.7      | Control Register (CONTROL) — EALLOW Protected                                                                              | 28  |
|       | 9.8      | Burst Size Register (BURST_SIZE) — EALLOW Protected                                                                        | 30  |
|       | 9.9      | BURST_COUNT Register                                                                                                       | 31  |
|       | 9.10     | Source Burst Step Register Size (SRC_BURST_STEP) — EALLOW Protected                                                        | 31  |
|       | 9.11     | Destination Burst Step Register Size (DST_BURST_STEP) — EALLOW Protected                                                   | 32  |
|       | 9.12     | Transfer Size Register (TRANSFER_SIZE) — EALLOW Protected                                                                  | 32  |
|       | 9.13     | Transfer Count Register (TRANSFER_COUNT)                                                                                   | 33  |
|       | 9.14     | Source Transfer Step Size Register (SRC_TRANSFER_STEP) — EALLOW Protected                                                  | 33  |
|       | 9.15     | Destination Transfer Step Size Register (DST_TRANSFER_STEP) — EALLOW Protected                                             | 34  |
|       | 9.16     | Source/Destination Wrap Size Register (SRC/DST_WRAP_SIZE) — EALLOW protected)                                              | 34  |
|       | 9.17     | Source/Destination Wrap Count Register (SCR/DST_WRAP_COUNT)                                                                | 35  |
|       | 9.18     | Source/Destination Wrap Step Size Registers (SRC/DST_WRAP_STEP) — EALLOW Protected                                         | 35  |
|       | 9.19     | Shadow Source Begin and Current Address Pointer Registers (SRC_BEG_ADDR_SHADOW/DST_BEG_ADDR_SHADOW) — All EALLOW Protected | 36  |
|       | 9.20     | Active Source Begin and Current Address Pointer Registers (SRC_BEG_ADDR/DST_BEG_ADDR)                                      | 36  |
|       | 9.21     | Shadow Destination Begin and Current Address Pointer Registers (SRC_ADDR_SHADOW/DST_ADDR_SHADOW) — All EALLOW Protected    | 37  |
|       | 9.22     | Active Destination Begin and Current Address Pointer Registers (SRC_ADDR/DST_ADDR)                                         | 37  |

### **List of Figures**

| 1  | DMA Block Diagram                                                                                   | 10 |
|----|-----------------------------------------------------------------------------------------------------|----|
| 2  | Peripheral Interrupt Trigger Input Diagram                                                          |    |
| 3  | 4-Stage Pipeline DMA Transfer                                                                       | 12 |
| 4  | 4-Stage Pipeline With One Read Stall (McBSP as source)                                              | 12 |
| 5  | DMA State Diagram                                                                                   |    |
| 6  | ADC Sync Input Diagram                                                                              | 21 |
| 7  | ADC Overrun Detection Logic                                                                         | 21 |
| 8  | DMA Control Register (DMACTRL)                                                                      | 23 |
| 9  | Debug Control Register (DEBUGCTRL)                                                                  | 24 |
| 10 | Revision Register (REVISION)                                                                        | 24 |
| 11 | Priority Control Register 1 (PRIORITYCTRL1)                                                         | 25 |
| 12 | Priority Status Register (PRIORITYSTAT)                                                             | 25 |
| 13 | Mode Register (MODE)                                                                                | 27 |
| 14 | Control Register (CONTROL)                                                                          | 28 |
| 15 | Burst Size Register (BURST_SIZE)                                                                    | 30 |
| 16 | Burst Count Register (BURST_COUNT)                                                                  | 31 |
| 17 | Source Burst Step Size Register (SRC_BURST_STEP)                                                    | 31 |
| 18 | Destination Burst Step Register Size (DST_BURST_STEP)                                               | 32 |
| 19 | Transfer Size Register (TRANSFER_SIZE)                                                              | 32 |
| 20 | Transfer Count Register (TRANSFER_COUNT)                                                            | 33 |
| 21 | Source Transfer Step Size Register (SRC_TRANSFER_STEP)                                              | 33 |
| 22 | Destination Transfer Step Size Register (DST_TRANSFER_STEP)                                         | 34 |
| 23 | Source/Destination Wrap Size Register (SRC/DST_WRAP_SIZE)                                           |    |
| 24 | Source/Destination Wrap Count Register (SCR/DST_WRAP_COUNT)                                         |    |
| 25 | Source/Destination Wrap Step Size Registers (SRC/DST_WRAP_STEP)                                     | 35 |
| 26 | Shadow Source Begin and Current Address Pointer Registers (SRC_BEG_ADDR_SHADOW/DST_BEG_ADDR_SHADOW) | 36 |
| 27 | Active Source Begin and Current Address Pointer Registers (SRC_BEG_ADDR/DST_BEG_ADDR)               | 36 |
| 28 | Shadow Destination Begin and Current Address Pointer Registers (SRC_ADDR_SHADOW/DST_ADDR_SHADOW)    | 37 |
| 29 | Active Destination Begin and Current Address Pointer Registers (SRC ADDR/DST ADDR)                  |    |

### **List of Tables**

| 1  | Peripheral Interrupt Trigger Source Options                                                                            | 11 |
|----|------------------------------------------------------------------------------------------------------------------------|----|
| 2  | DMA Register Summary                                                                                                   | 22 |
| 3  | DMA Control Register (DMACTRL) Field Descriptions                                                                      | 23 |
| 4  | Debug Control Register (DEBUGCTRL) Field Descriptions                                                                  | 24 |
| 5  | Revision Register (REVISION) Field Descriptions                                                                        | 24 |
| 6  | Priority Control Register 1 (PRIORITYCTRL1) Field Descriptions                                                         | 25 |
| 7  | Priority Status Register (PRIORITYSTAT) Field Descriptions                                                             | 25 |
| 8  | Mode Register (MODE) Field Descriptions                                                                                | 27 |
| 9  | Control Register (CONTROL) Field Descriptions                                                                          | 29 |
| 10 | Burst Size Register (BURST_SIZE) Field Descriptions                                                                    | 30 |
| 11 | Burst Count Register (BURST_COUNT) Field Descriptions                                                                  | 31 |
| 12 | Source Burst Step Size Register (SRC_BURST_STEP) Field Descriptions                                                    | 31 |
| 13 | Destination Burst Step Register Size (DST_BURST_STEP) Field Descriptions                                               | 32 |
| 14 | Transfer Size Register (TRANSFER_SIZE) Field Descriptions                                                              | 32 |
| 15 | Transfer Count Register (TRANSFER_COUNT) Field Descriptions                                                            | 33 |
| 16 | Source Transfer Step Size Register (SRC_TRANSFER_STEP) Field Descriptions                                              | 33 |
| 17 | Destination Transfer Step Size Register (DST_TRANSFER_STEP) Field Descriptions                                         | 34 |
| 18 | Source/Destination Wrap Size Register (SRC/DST_WRAP_SIZE) Field Descriptions                                           | 34 |
| 19 | Source/Destination Wrap Count Register (SCR/DST_WRAP_COUNT) Field Descriptions                                         | 35 |
| 20 | Source/Destination Wrap Step Size Registers (SRC/DST_WRAP_STEP) Field Descriptions                                     | 35 |
| 21 | Shadow Source Begin and Current Address Pointer Registers (SRC_BEG_ADDR_SHADOW/DST_BEG_ADDR_SHADOW) Field Descriptions | 36 |
| 22 | Active Source Begin and Current Address Pointer Registers (SRC_BEG_ADDR/DST_BEG_ADDR) Field Descriptions               | 36 |
| 23 | Shadow Destination Begin and Current Address Pointer Registers (SRC_ADDR_SHADOW/DST_ADDR_SHADOW) Field Descriptions    | 37 |
| 24 | Active Destination Begin and Current Address Pointer Registers (SRC_ADDR/DST_ADDR) Field                               |    |
|    | Descriptions                                                                                                           | 37 |



### Read This First

This reference guide describes the features and behavior of the DMA module found on the TMS320x2833x Digital Signal Controllers from Texas Instruments.

#### **Notational Conventions**

This document uses the following conventions.

- Hexadecimal numbers are shown with the suffix h or with a leading 0x. For example, the following number is 40 hexadecimal (decimal 64): 40h or 0x40.
- Registers in this document are shown in figures and described in tables.
  - Each register figure shows a rectangle divided into fields that represent the fields of the register.
     Each field is labeled with its bit name, its beginning and ending bit numbers above, and its read/write properties below. A legend explains the notation used for the properties.
  - Reserved bits in a register figure designate a bit that is used for future device expansion.

#### **Related Docs**

The following documents support the 2833x devices and can be found at the Texas Instruments web site: www.ti.com.

#### Data Manual—

SPRS439— TMS320F28335, F28334, F28332 Digital Signal Controllers (DSCs) Data Manual contains the pinout, signal descriptions, as well as electrical and timing specifications for the F2833x devices.

#### CPU User's Guides—

#### SPRU430— TMS320C28x DSP CPU and Instruction Set Reference Guide

describes the central processing unit (CPU) and the assembly language instructions of the TMS320C28x fixed-point digital signal processors (DSPs). It also describes emulation features available on these DSPs.

#### SPRUEO2— TMS320C28x Floating Point Unit and Instruction Set Reference Guide

describes the floating-point unit and includes the instructions for the FPU.

#### Peripheral Guides—

#### SPRU566— TMS320x28xx, 28xxx Peripheral Reference Guide

describes the peripheral reference guides of the 28x digital signal processors (DSPs).

**SPRUFB0**— TMS320x2833x System Control and Interrupts Reference Guide describes the various interrupts and system control features of the 2833x digital signal controllers (DSCs).

#### SPRU812— TMS320x2833x Analog-to-Digital Converter (ADC) Reference Guide

describes how to configure and use the on-chip ADC module, which is a 12-bit pipelined ADC.

#### SPRU949— TMS320x2833x External Memory Interface (XINTF) User's Guide

describes the XINTF, which is a nonmultiplexed asynchronous bus, as it is used on the 2833x devices.

SPRU963— TMS320x2833x Boot ROM User's Guide



describes the purpose and features of the bootloader (factory-programmed boot-loading software) and provides examples of code. It also describes other contents of the device on-chip boot ROM and identifies where all of the information is located within that memory.

- SPRUFB7— TMS320x2833x Multichannel Buffered Serial Port (McBSP) User's Guide
  - describes the McBSP available on the F2833x devices. The McBSPs allow direct interface between a DSP and other devices in a system.
- **SPRUFB8** TMS320x2833x Direct Memory Access (DMA) Reference Guide describes the DMA on the 2833x devices.
- SPRU791— TMS320x28xx, 28xxx Enhanced Pulse Width Modulator (ePWM) Module Reference Guide describes the main areas of the enhanced pulse width modulator that include digital motor control, switch mode power supply control, UPS (uninterruptible power supplies), and other forms of power conversion.
- **SPRU924** TMS320x28xx, 28xxx High-Resolution Pulse Width Modulator (HRPWM) describes the operation of the high-resolution extension to the pulse width modulator (HRPWM).
- **SPRU807** TMS320x28xx, 28xxx Enhanced Capture (eCAP) Module Reference Guide describes the enhanced capture module. It includes the module description and registers.
- SPRU790— TMS320x28xx, 28xxx Enhanced Quadrature Encoder Pulse (eQEP) Reference Guide describes the eQEP module, which is used for interfacing with a linear or rotary incremental encoder to get position, direction, and speed information from a rotating machine in high performance motion and position control systems. It includes the module description and registers.
- SPRU074— TMS320x28xx, 28xxx Enhanced Controller Area Network (eCAN) Reference Guide describes the eCAN that uses established protocol to communicate serially with other controllers in electrically noisy environments.
- SPRU051— TMS320x28xx, 28xxx Serial Communication Interface (SCI) Reference Guide describes the SCI, which is a two-wire asynchronous serial port, commonly known as a UART. The SCI modules support digital communications between the CPU and other asynchronous peripherals that use the standard non-return-to-zero (NRZ) format.
- SPRU059— TMS320x28xx, 28xxx Serial Peripheral Interface (SPI) Reference Guide describes the SPI a high-speed synchronous serial input/output (I/O) port that allows a serial bit stream of programmed length (one to sixteen bits) to be shifted into and out of the device at a programmed bit-transfer rate.
- SPRU721— TMS320x28xx, 28xxx Inter-Integrated Circuit (I2C) Reference Guide describes the features and operation of the inter-integrated circuit (I2C) module that is available on the TMS320x280x digital signal processor (DSP).

#### Tools Guides—

- SPRU513— TMS320C28x Assembly Language Tools User's Guide
  - describes the assembly language tools (assembler and other tools used to develop assembly language code), assembler directives, macros, common object file format, and symbolic debugging directives for the TMS320C28x device.
- SPRU514— TMS320C28x Optimizing C Compiler User's Guide

  describes the TMS320C28x<sup>™</sup> C/C++ compiler. This compiler accepts ANSI standard C/C++ source code and produces TMS320 DSP assembly language source code for the TMS320C28x device.
- SPRU608— The TMS320C28x Instruction Set Simulator Technical Overview describes the simulator, available within the Code Composer Studio for TMS320C2000 IDE, that simulates the instruction set of the C28x<sup>™</sup> core.



**SPRU625**— TMS320C28x DSP/BIOS Application Programming Interface (API) Reference Guide describes development using DSP/BIOS.



## TMS320x2833x Direct Memory Access (DMA) Module

The direct memory access (DMA) module provides a hardware method of transferring data between peripherals and/or memory without intervention from the CPU, thereby freeing up bandwidth for other system functions. Additionally, the DMA has the capability to orthogonally rearrange the data as it is transferred as well as "ping-pong" data between buffers. These features are useful for structuring data into blocks for optimal CPU processing.

#### 1 Introduction

The strength of a digital signal controller (DSC) is not measured purely in processor speed, but in total system capabilities. As a part of the equation, any time the CPU bandwidth for a given function can be reduced, the greater the system capabilities. Many times applications spend a significant amount of their bandwidth moving data, whether it is from off-chip memory to on-chip memory, or from a peripheral such as an analog-to-digital converter (ADC) to RAM, or even from one peripheral to another. Furthermore, many times this data comes in a format that is not conducive to the optimum processing powers of the CPU. The DMA module described in this reference guide has the ability to free up CPU bandwidth and rearrange the data into a pattern for more streamlined processing.

The DMA module is an event-based machine, meaning it requires a peripheral interrupt trigger to start a DMA transfer. Although it can be made into a periodic time-driven machine by configuring a timer as the interrupt trigger source, there is no mechanism within the module itself to start memory transfers periodically. The interrupt trigger source for each of the six DMA channels can be configured separately and each channel contains its own independent PIE interrupt to let the CPU know when a DMA transfers has either started or completed. Five of the six channels are exactly the same, while Channel 1 has one additional feature: the ability to be configured at a higher priority than the others. At the heart of the DMA is a state machine and tightly coupled address control logic. It is this address control logic that allows for rearrangement of the block of data during the transfer as well as the process of *ping-ponging* data between buffers. Each of these features, along with others will be discussed in detail in this document.

#### DMA Overview:

- 6 channels with independent PIE interrupts
- Peripheral interrupt trigger sources
  - ADC sequencer 1 and sequencer 2
  - Multichannel Buffered Serial Port A and B (McBSP-A, McBSP-B) transmit and receive
  - XINT1-7 and XINT13
  - CPU Timers
  - Software
- Data sources/destinations:
  - L4-L7 16K x 16 SARAM
  - All XINTF zones
  - ADC memory bus mapped result registers
  - McBSP-A and McBSP-B transmit and receive buffers
- Word Size: 16-bit or 32-bit (McBSPs limited to 16-bit)
- Throughput: 4 cycles/word (5 cycles/word for McBSP reads)



#### 2 Architecture

### 2.1 Block Diagram

Figure 1 shows a device level block diagram of the DMA.

CPU bus INT7 ADC CPU CPU External ADC PF0 interrupts timers ADC control ADC PIE I/F RESULT and PF2 ADC registers RESULT I/F DINT[CH1:CH6] DMA registers PF0 I/F XINTF zones interface XINTF mem zones L4 L4 SARAM I/F (4Kx16) CPU L5 McBSP L5 Event DMA SARAM Α I/F PF3 (4Kx16) triggers 6-ch I/F **McBSP** L6 B L6 SARAM I/F (4Kx16) L7 L7 SARAM I/F (4Kx16) DMA bus

Figure 1. DMA Block Diagram

#### 2.2 Peripheral Interrupt Event Trigger Sources

The peripheral interrupt event trigger can be independently configured as one of eighteen different sources for each of the six DMA channels. Included in these sources are 8 external interrupt signals which can be connected to most of the general-purpose input/output (GPIO) pins on the device. This adds significant flexibility to the event trigger capabilities. A bit field called PERINTSEL in the MODE register of each channel is used to select that channels interrupt trigger source. An active peripheral interrupt trigger will be latched into the PERINTFLG bit of the CONTROL register, and if the respective interrupt and DMA channel is enabled (see the MODE.CHx[PERINTE] and CONTROL.CHx[RUNSTS] bits), it will be serviced by the DMA channel. Upon receipt of a peripheral interrupt event signal, the DMA will automatically send a clear signal to the interrupt source so that subsequent interrupt events will occur.

Regardless of the value of the MODE.CHx[PERINTSEL] bit field, software can always force a trigger by using the CONTROL.CHx[PERINTFRC] bit. Likewise, software can always clear a pending DMA trigger using the CONTROL.CHx[PERINTCLR] bit.

Once a particular interrupt trigger sets a channel's PERINTFLG bit, the bit stays pending until the priority logic of the state machine starts the burst transfer for that channel. Once the burst transfer starts, the flag is cleared. If a new interrupt trigger is generated while a burst is in progress, the burst will complete before responding to the new interrupt trigger (after proper prioritization). If a third interrupt trigger occurs before the pending interrupt is serviced, an error flag is set in the CONTROL.CHx[OVRFLG] bit. If a peripheral interrupt trigger occurs at the same time as the latched flag is being cleared, the peripheral interrupt trigger has priority and the PERINTFLG will remain set.



Figure 2 shows a diagram of the trigger select circuit. See the MODE.CHx[PERINTSEL] bit field description for the complete list of peripheral interrupt trigger sources.

Clear interrupt CONTROL.CHx[PERINTFLG] MODE.CHx [PERINTSEL] DMA Clear channel x processing Peripheral None logic İnt CONTROL.CHx Latch SEQ1INT [PERINTCLR] SEQ2INT MODE.CHx [PERINTE] Set **MREVTA MXEVTB** CONTROL.CHx **MREVTB** [PERINTFRC] Clear peripheral interrupt trigger flag if appropriate

Figure 2. Peripheral Interrupt Trigger Input Diagram

Table 1 shows the interrupt trigger source options that are available for each channel.

| Peripheral          | Interrupt Trigger Source                      |
|---------------------|-----------------------------------------------|
| CPU                 | DMA Software bit (CHx.CONTROL.PERINTFRC) only |
| ADC                 | Sequencer 1 Interrupt                         |
|                     | Sequencer 2 Interrupt                         |
| External Interrupts | External Interrupt 1                          |
|                     | External Interrupt 2                          |
|                     | External Interrupt 3                          |
|                     | External Interrupt 4                          |
|                     | External Interrupt 5                          |
|                     | External Interrupt 6                          |
|                     | External Interrupt 7                          |
|                     | External Interrupt 13                         |
| CPU Timers          | Timer 0 Overflow                              |
|                     | Timer 1 Overflow                              |
|                     | Timer 2 Overflow                              |
| McBSP-A             | McBSP-A Transmit Buffer Empty                 |
|                     | McBSP-A Receive Buffer Full                   |
| McBSP-B             | McBSP-B Transmit Buffer Empty                 |
|                     | McBSP-B Receive Buffer Full                   |
|                     |                                               |

**Table 1. Peripheral Interrupt Trigger Source Options** 



#### 2.3 DMA Bus

The DMA bus architecture consists of a 22-bit address bus, a 32-bit data read bus, and a 32-bit data write bus. Memories and register locations connected to the DMA bus are via interfaces that sometimes share resources with the CPU memory or peripheral bus. Arbitration rules are defined in Section 4. The following resources are connected to the DMA bus:

- XINTF Zones 0, 6 & 7
- L4 SARAM
- L5 SARAM
- L6 SARAM
- L7 SARAM
- **ADC Memory Mapped Result Registers**
- McBSP-A and McBSP-B Data Receive Registers (DRR2/DRR1) and Data Transmit Registers (DXR2/DXR1)

#### 3 **Pipeline Timing and Throughput**

The DMA consists of a 4-stage pipeline as shown in Figure 3. The one exception to this is when a DMA channel is configured to have one of the McBSPs as its data source. A read of a McBSP DRR register stalls the DMA bus for one cycle during the read portion of the transfer, as shown in Figure 4.

Figure 3. 4-Stage Pipeline DMA Transfer SYSCLK Out Out Out Out Out SRC DST SRC DST **SRC** Addr bus addr addr addr addr addr (N) (N+1)(N+1)(N+2)(N) Write Read Write Read Read SRC SRC DST SRC DST Data bus data data data data data (N) (N) (N+1)(N+1)(N+2)Gen Gen Gen Gen Gen SRC DST SRC DST SRC addr addr addr addr addr address (N+1)(N+1)(N+2)(N+2)(N+3)

Generate

Figure 4. 4-Stage Pipeline With One Read Stall (McBSP as source)





In addition to the pipeline there are a few other behaviors of the DMA that affect it's total throughput

- A 1-cycle delay is added at the beginning of each burst
- A 1-cycle delay is added when returning from a CH1 high priority interrupt
- 32-bit transfers run at double the speed of a 16-bit transfer (i.e., it takes the same amount of time to transfer a 32-bit word as it does a 16-bit word)
- Collisions with the CPU may add delay slots (see Section 4)

For example, to transfer 128 16-bit words from ADC to RAM a channel can be configured to transfer 8 bursts of 16 words/burst. This will give:

8 bursts \* [(4 cycles/word \* 16 words/burst) + 1] = 520 cycles

If instead the channel were configured to transfer the same amount of data 32 bits at a time (the word size is configured to 32 bits) the transfer would take:

8 bursts \* [(4 cycles/word \* 8 words/burst) + 1] = 264 cycles

#### 4 CPU Arbitration

Typically, DMA activity is independent of the CPU activity. Under the circumstance where both the DMA and the CPU are attempting to access memory or a peripheral register within the same interface concurrently, an arbitration procedure will occur. The one exception is with the memory mapped (PF0) ADC registers, which do not create a conflict when read by both the CPU and the DMA simultaneously, even if different addresses are accessed. Any combined accesses between the different interfaces, or where the CPU access is outside of the interface that the DMA is accessing do not create a conflict.

The interfaces which internally contain conflicts are:

- XINTF Memory Zones 0, 6 and 7
- L4 RAM
- L5 RAM
- L6 RAM
- L7 RAM
- Peripheral Frame 3 (McBSP-A and McBSP-B)

#### 4.1 For the External Memory Interface (XINTF) Zones

- If the CPU and the DMA attempt an access to any of the XINTF zones on the same cycle, the DMA is serviced first, followed by all the pending CPU accesses (in the proper priority order for CPU accesses: write → read → fetch).
- If CPU accesses to an XINTF zone are pending or being processed by the XINTF and a DMA access
  to an XINTF zone is attempted, the DMA access is stalled until all CPU pending accesses are
  completed. For example, if a CPU write and read access is pending and a fetch is in progress, first the
  fetch is completed, then the CPU write is performed, then the CPU read is performed, and then the
  DMA access is performed.
- There is a 1 cycle stall if simultaneous write accesses by the CPU and the DMA are attempted.

If the DMA or CPU is used to write to the XINTF zones, then the write buffer of the XINTF can help to avoid CPU or DMA stalls. If the CPU or DMA are performing reads from XINTF, then significant stalls can occur. The only concern here is if the DMA is stalled and the DMA misses other higher priority DMA events such as servicing the ADC which can generate data at a high rate. In such situations, the DMA should not be used to transfer data on XINTF, if the stalls are too long that there is potential to miss other DMA events.



The DMA does not support abort mechanisms for DMA reads from XINTF. If the DMA is performing an access to one of the XINTF zones and the DMA access is stalled (XREADY not responding) then the CPU can issue a HARDRESET that would abort the access. HARDRESET behaves like a System Reset on the DMA. Likewise, a HARDRESET needs to be applied to the XINTF hence releasing the peripheral from the struck ready condition. Any data that is write buffered or pending on the XINTF or DMA will be lost.

#### 4.2 For All Other Peripherals/Memories

- If the CPU and the DMA make an access to the same interface in the same cycle, the DMA has priority and the CPU is stalled.
- If a CPU access to an interface is in progress and another CPU access to the same interface is pending, for example, the CPU is performing a write operation and a read operation from the CPU is pending, then a DMA access to that same interface has priority over the pending CPU access when the current CPU access completes.

Note: If the CPU is performing a read-modify-write operation and the DMA performs a write to the same location, the DMA write may be lost if the operation occurs in between the CPU read and the CPU write. For this reason, it is advised not to mix such CPU accesses with DMA accesses to the same locations.

In the case of RAM, a ping-pong scheme can be implemented to avoid the CPU and the DMA accessing the same RAM block concurrently, thus avoiding any stalls or corruption issues.

#### 5 **Channel Priority**

Two priority schemes exist when determining channel priority: Round-robin mode and Channel 1 high-priority mode.

#### 5.1 Round-Robin Mode

In this mode, all channels have equal priority and each enabled channel is serviced in round-robin fashion as follows:

$$\text{CH1} \rightarrow \text{CH2} \rightarrow \text{CH3} \rightarrow \text{CH4} \rightarrow \text{CH5} \rightarrow \text{CH6} \rightarrow \text{CH1} \rightarrow \text{CH2} \rightarrow ...$$

In the case above, after each channel has transferred a burst of words, the next channel is serviced. You can specify the size of the burst for each channel. Once CH6 (or the last enabled channel) has been serviced, and no other channels are pending, the round-robin state machine enters an idle state.

From the idle state, channel 1 (if enabled) is always serviced first. However, if the DMA is currently processing another channel x, all other pending channels between x and the end of the round are serviced before CH1. It is in this sense that all the channels are of equal priority. For instance, take an example where CH1, CH4, and CH5 are enabled in round-robin mode and CH4 is currently being processed. Then CH1 and CH5 both receive an interrupt trigger from their respective peripherals before CH4 completes. CH1 and CH5 are now both pending. When CH4 completes its burst, CH5 will be serviced next. Only after CH5 completes will CH1 be serviced. Upon completion of CH1, if there are no more channels pending, the round-robin state machine will enter an idle state.

A more complicated example is shown below:

- Assume all channels are enabled, and the DMA is in an idle state,
- Initially a trigger occurs on CH1, CH3, and CH5 on the same cycle,
- When the CH1 burst transfer starts, requests from CH3 and CH5 are pending,
- Before completion of the CH1 burst, the DMA receives a request from CH2. Now the pending requests are from CH2, CH3, and CH5,
- After completing the CH1 burst, CH2 will be serviced since it is next in the round-robin scheme after
- After the burst from CH2 is finished, the CH3 burst will be serviced, followed by CH5 burst.



- Now while the CH5 burst is being serviced, the DMA receives a request from CH1, CH3, and CH6.
- The burst from CH6 will start after the completion of the CH5 burst since it is the next channel after CH5 in the round-robin scheme.
- This will be followed by the CH1 burst and then the CH3 burst
- After the CH3 burst finishes, assuming no more triggers have occurred, the round-robin state machine
  will enter an idle state.

The round-robin state machine may be reset to the idle state via the DMACTRL[PRIORITYRESET] bit.

### 5.2 Channel 1 High Priority Mode

In this mode, if a CH1 trigger occurs, the current word transfer on any other channel is completed (not the complete burst), execution is halted, and CH1 is serviced for the complete burst count. When the CH1 burst is complete, execution returns to the channel that was active when the CH1 trigger occurred. All other channels have equal priority and each enabled channel is serviced in round-robin fashion as follows:

Higher Priority: CH1

Lower priority:  $CH2 \rightarrow CH3 \rightarrow CH4 \rightarrow CH5 \rightarrow CH6 \rightarrow CH2 \rightarrow ...$ 

Given an example where CH1, CH4 and CH5 are enabled in Channel 1 High Priority Mode and CH4 is currently being processed. Then CH1 and CH5 both receive an interrupt trigger from their respective peripherals before CH4 completes. CH1 and CH5 are now both pending. When the current CH4 word transfer is completed, regardless of whether the DMA has completed the entire CH4 burst, CH4 execution will be suspended and CH1 will be serviced. After the CH1 burst completes, CH4 will resume execution.

Upon completion of CH4, CH5 will be serviced. After CH5 completes, if there are no more channels pending, the round-robin state machine will enter an idle state.

Typically Channel 1 would be used in this mode for the ADC, since its data rate is so high. However, Channel 1 High Priority Mode may be used in conjunction with any peripheral.

#### 6 Address Pointer and Transfer Control

The DMA state machine is, at its most basic level, two nested loops. The inner loop transfers a burst of data when a peripheral interrupt trigger is received. A burst is the smallest amount of data that can be transferred at one time and its size is defined by the BURST\_SIZE register for each channel. The BURST\_SIZE register allows a maximum of 32 sixteen-bit words to be transferred in one burst. The outer loop, whose size is set by the TRANSFER\_SIZE register for each channel, defines how many bursts are performed in the entire transfer. Since TRANSFER\_SIZE is a 16-bit register, the total size of a transfer allowed is well beyond any practical requirement. One CPU interrupt is generated, if enabled, for each transfer. This interrupt can be configured to occur at the beginning or the end of the transfer via the MODE.CHx[CHINTMODE] bit.

In the default setting of the MODE.CHx[ONESHOT] bit, the DMA transfers one burst of data each time a peripheral interrupt trigger is received. After the burst is completed, the state machine moves on to the next pending channel in the priority scheme, even if another trigger for the channel just completed is pending. This feature keeps any single channel from monopolizing the DMA bus. If a transfer of more than the maximum number of words per burst is desired for a single trigger, the MODE.CHx[ONESHOT] bit can be set to complete the entire transfer when triggered. Care is advised when using this mode, since this can create a condition where one trigger uses up the majority of the DMA bandwidth.



Each DMA channel contains a shadowed address pointer for the source and the destination address. These pointers, SRC\_ADDR and DST\_ADDR, can be independently controlled during the state machine operation. At the beginning of each transfer, the shadowed version of each pointer is copied into its respective active register. During the burst loop, after each word is transferred, the signed value contained in the appropriate source or destination BURST\_STEP register is added to the active SRC/DST\_ADDR register. During the transfer loop, after each burst is complete, there are two methods that can be used to modify the active address pointer. The first, and default, method is by adding the signed value contained in the SRC/DST\_TRANSFER\_STEP register to the appropriate pointer. The second is via a process called wrapping, where a wrap address is loaded into the active address pointer. When a wrap procedure occurs, the associated SRC/DST\_TRANSFER\_STEP register has no effect.

Address wrapping occurs when a number of bursts specified by the appropriate SRC/DST\_WRAP\_SIZE register completes. Each DMA channel contains two shadowed wrap address pointers, SRC\_BEG\_ADDR and DST\_BEG\_ADDR, allowing the source and destination wrapping to be independent of each other. Like the SRC\_ADDR and DST\_ADDR registers, the active SRC/DST\_BEG\_ADDR registers are loaded from their shadow counterpart at the beginning of a transfer. When the specified number of bursts has occurred, a two part wrap procedure takes place:

- The appropriate active SRC/DST\_BEG\_ADDR register is incremented by the signed value contained in the SRC/DST\_WRAP\_STEP register, then
- The new active SRC/DST BEG ADDR register is loaded into the active SRC/DST ADDR register.

Additionally the wrap counter (SRC/DST\_WRAP\_COUNT) register is reloaded with the SRC/DST\_WRAP\_SIZE value to setup the next wrap period. This allows the channel to wrap multiple times within a single transfer. Combined with the first bullet above, this allows the channel to address multiple buffers within a single transfer.

The DMA contains both an active and shadow set of the following address pointers. When a DMA transfer begins, the shadow register set is copied to the active working set of registers. This allows you to program the values of the shadow registers for the next transfer while the DMA works with the active set. It also allows you to implement Ping-Pong buffer schemes without disrupting the DMA channel execution.

**Source/Destination Address Pointers (SRC/DST\_ADDR)**—The value written into the shadow register is the start address of the first location where data is read or written to.

At the beginning of a transfer the shadow register is copied into the active register. The active register performs as the current address pointer.

Source/Destination Begin Address Pointers (SRC/DST\_BEG\_ADDR)—This is the wrap pointer.

The value written into the shadow register will be loaded into the active register at the start of a transfer. On a wrap condition, the active register will be incremented by the signed value in the appropriate SRC/DST\_WRAP\_STEP register prior to being loaded into the active SRC/DST\_ADDR register.

For each channel, the transfer process can be controlled with the following size values:

**Source and Destination Burst Size (BURST\_SIZE):** —This specifies the number of words to be transferred in a burst.

This value is loaded into the BURST\_COUNT register at the beginning of each burst. The BURST\_COUNT decrements each word that is transferred and when it reaches a zero value, the burst is complete, indicating that the next channel can be serviced. The behavior of the current channel is defined by the ONE\_SHOT bit in the MODE register. The maximum size of the burst is dictated by the type of peripheral. For the ADC, the burst size could be all 16 registers (if all 16 registers are used). For a McBSP peripheral, the burst size is limited to 1 since there is no FIFO and the receive or transmit data register must be loaded or copied every word transferred. For RAM the burst size can be up to the maximum allowed by the BURST\_SIZE register, which is 32.



Source and Destination Transfer Size (TRANSFER\_SIZE): —This specifies the number of bursts to be transferred before per CPU interrupt (if enabled).

Whether this interrupt is generated at the beginning or the end of the transfer is defined in the CHINTMODE bit in the MODE register. Whether the channel remains enabled or not after the transfer is completed is defined by the CONTINUOUS bit in the MODE register. The TRANSFER\_SIZE register is loaded into the TRANSFER\_COUNT register at the beginning of each transfer. The TRANSFER\_COUNT register keeps track of how many bursts of data the channel has transferred and when it reaches zero, the DMA transfer is complete.

Source/Destination Wrap Size (SRC/DST WRAP SIZE)—This specifies the number of bursts to be transferred before the current address pointer wraps around to the beginning.

This feature is used to implement a circular addressing type function. This value is loaded into the appropriate SRC/DST\_WRAP\_COUNT register at the beginning of each transfer. The SRC/DST\_WRAP\_COUNT registers keep track of how many bursts of data the channel has transferred and when they reaches zero, the wrap procedure is performed on the appropriate source or destination address pointer. A separate size and count register is allocated for source and destination pointers. To disable the wrap function, assign the value of these registers to be larger than the TRANSFER\_SIZE.

Note: The value written to the SIZE registers is one less than the intended size. So, to transfer three 16-bit words, the value 2 should be placed in the STEP\_SIZE register.

Regardless of the state of the DATASIZE bit, the value specified in the SIZE registers are for 16-bit addresses. So, to transfer three 32-bit words, the value 5 should be placed in the STEP SIZE register.

For each source/destination pointer, the address changes can be controlled with the following step values:

Source/Destination Burst Step (SRC/DST BURST STEP)—Within each burst transfer, the address source and destination step sizes are specified by these registers.

This value is a signed 2's compliment number so that the address pointer can be incremented or decremented as required. If no increment is desired, such as when accessing the McBSP data receive or transmit registers, the value of these registers should be set to zero.

Source/Destination Transfer Step (SRC/DST\_TRANSFER\_STEP)—This specifies the address offset to start the next burst transfer after completing the current burst transfer.

This is used in cases where registers or data memory locations are spaced at constant intervals. This value is a signed 2's compliment number so that the address pointer can be incremented or decremented as required.

Source/Destination Wrap Step (SRC/DST\_WRAP\_STEP): —When the wrap counter reaches zero, this value specifies the number of words to add/subtract from the BEG ADDR pointer and hence sets the new start address.

This implements a circular type of addressing mode, useful in many applications. This value is a signed 2's compliment number so that the address pointer can be incremented or decremented as required.

Note: Regardless of the state of the DATASIZE bit, the value specified in the STEP registers are for 16-bit addresses. So, to increment one 32-bit address, a value of 2 should be placed in these registers.



Three modes are provided to control the way the state machine behaves during the burst loop and the transfer loop:

One Shot Mode (ONESHOT)—If one shot mode is enabled when an interrupt event trigger occurs, the DMA will continue transferring data in bursts until TRANSFER COUNT is zero. If one shot mode is disabled, then an interrupt event trigger is required for each burst transfer and this will continue until TRANSFER COUNT is zero.

Note: When ONESHOT mode is enabled, the DMA will continuously transfer bursts of data on the given channel until the TRANSFER COUNT value is zero. This could potentially hog the bandwidth of a peripheral and cause long CPU stalls to occur. To avoid this, you could configure a CPU timer (or similar) and disable ONESHOT so as to avoid this situation.

Continuous Mode (CONTINUOUS)—If continuous mode is disabled the RUNSTS bit in the CONTROL register is cleared at the end of the transfer, disabling the DMA channel.

The channel must be re-enabled by setting the RUN bit in the CONTROL register before another transfer can be started on that channel. If the continuous mode is enabled the RUNSTS bit is not cleared at the end of the transfer.

Channel Interrupt Mode (CHINTMODE)—This mode bit selects whether the DMA interrupt from the respective channel is generated at the beginning of a new transfer or at the end of the transfer.

If implementing a ping-pong buffer scheme with continuous mode of operation, then the interrupt would be generated at the beginning, just after the working registers are copied to the shadow set. If the DMA does not operate in continuous mode, then the interrupt is typically generated at the end when the transfer is complete.

All of the above features and modes are shown in Figure 5.





Figure 5. DMA State Diagram



The following items are in reference to Figure 5.

- The HALT points represent where the channel halts operation when interrupted by a high priority channel 1 trigger, or when the HALT command is set, or when an emulation halt is issued and the FREE bit is cleared to 0.
- The ADDR registers are not affected by BEG\_ADDR at the start of a transfer. BEG\_ADDR only affects the ADDR registers on a wrap or sync error. Following is what happens to each of the ADDR registers when a transfer first starts:
  - BEG\_ADDR\_SHADOW remains unchanged.
  - ADDR\_SHADOW remains unchanged.
  - BEG\_ADDR = BEG\_ADDR\_SHADOW
  - ADDR = ADDR SHADOW
- The active registers get updated when a wrap occurs. The shadow registers remain unchanged. Specifically:
  - BEG\_ADDR\_SHADOW remains unchanged.
  - ADDR\_SHADOW remains unchanged.
  - BEG\_ADDR += WRAP\_STEP
  - ADDR = BEG\_ADDR
- The active registers get updated when a sync error occurs. The shadow registers remain unchanged.
   Specifically:
  - BEG\_ADDR\_SHADOW remains unchanged.
  - ADDR\_SHADOW remains unchanged.
  - BEG\_ADDR remains unchanged.
  - ADDR = BEG\_ADDR

Probably the easiest way to remember all this is that:

- The shadow registers never change except by software.
- The active registers never change except by hardware, and a shadow register is only copied into its own active register, never an active register by another name.

#### 7 ADC Sync Feature

The DMA provides a hardware method of synchronizing to the ADC Sequencer 1 interrupt (SEQ1INT) when it is running in continuous conversion mode with the sequencer override function enabled. In this specific mode, the ADC will be continuously converting a sequence of ADC channels without resetting the sequencer pointer at the end of each sequence. Since the DMA does not know which ADC RESULT register the sequencer pointer is pointing to when it receives a trigger, there is a potential for the DMA and the ADC to be out of step. For this reason, when the ADC is configured in this mode, it provides a synchronization signal to the DMA each time an event trigger is generated for a sequence starting at the RESULTO register. The DMA expects this signal to line up with a wrap procedure or the beginning of a transfer. If it does not, a re-sync procedure occurs:

- Reload the WRAP\_COUNT register with WRAP\_SIZE
- Load the ADDR.active register with BEG\_ADDR.active
- 3. Set the SYNCERR bit in the CONTROL register

This allows the use of multiple buffers to store the data and for the DMA and the ADC to resynchronize if necessary. For example, assume four ADC channels are configured to be converted at a time on sequencer 1. Since the maximum length of sequencer 1 is eight elements, the sequencer will reset itself, and generate a sync signal every other sequence. Assume the software expects that the first four results will be placed by the DMA into Buffer A, and the second four into Buffer B. If DMA activity becomes overburdened and an event trigger is lost, the DMA and the ADC will become unsynchronized. At this point the DMA will set the SYNCERR bit in the CONTROL register and perform the above re-sync procedure, bringing the DMA and the ADC back into synchronization.

Alternatively, the sync feature can be configured to work on the source address pointer via the SYNCSEL bit in the MODE register.

20



As shown in Figure 6, the synchronization source is chosen by the PERINTSEL bit field in the MODE register. If the SYNC feature is enabled for the selected source and channel, the transfer for that channel will not commence until reception of the first SYNC after the RUN bit is set. All peripheral interrupt triggers are ignored up to the first SYNC event.



Figure 6. ADC Sync Input Diagram

#### 8 ADC Overrun

The DMA contains overrun detection logic. When a peripheral event trigger is received by the DMA, the PERINTFLG bit in the CONTROL register is set, pending the channel to the DMA state machine. When the burst for that channel is started, the PERINTFLG is cleared. If however, before the burst is started and the PERINTFLG is still set, another event trigger arrives from the same peripheral, it will be lost. This condition will set the OVRFLG bit in the CONTROL register as in Figure 7. If the overrun interrupt is enabled then the channel interrupt will be generated to the PIE module.



Figure 7. ADC Overrun Detection Logic



### 9 Register Descriptions

The complete DMA register set is shown in Table 2.

### Table 2. DMA Register Summary<sup>(1)</sup>

| Address          | Acronym                       | Description                                                    | Section      |
|------------------|-------------------------------|----------------------------------------------------------------|--------------|
| DMA Contro       | ol, Mode and Status Registers | ·                                                              |              |
| 0x1000           | DMACTRL                       | DMA Control Register                                           | Section 9.1  |
| 0x1001           | DEBUGCTRL                     | Debug Control Register                                         | Section 9.2  |
| 0x1002           | REVISION                      | Peripheral Revision Register                                   | Section 9.3  |
| 0x1003           | Reserved                      | Reserved                                                       |              |
| 0x1004           | PRIORITYCTRL1                 | Priority Control Register 1                                    | Section 9.4  |
| 0x1005           | Reserved                      | Reserved                                                       |              |
| 0x1006           | PRIORITYSTAT                  | Priority Status Register                                       | Table 7      |
| 0x1007<br>0x101F | Reserved                      | Reserved                                                       |              |
| DMA Chann        | nel 1 Registers               |                                                                |              |
| 0x1020           | MODE                          | Mode Register                                                  | Section 9.6  |
| 0x1021           | CONTROL                       | Control Register                                               | Section 9.7  |
| 0x1022           | BURST_SIZE                    | Burst Size Register                                            | Section 9.8  |
| 0x1023           | BURST_COUNT                   | Burst Count Register                                           | Section 9.9  |
| 0x1024           | SRC_BURST_STEP                | Source Burst Step Size Register                                | Section 9.10 |
| 0x1025           | DST_BURST_STEP                | Destination Burst Step Size Register                           | Section 9.11 |
| 0x1026           | TRANSFER_SIZE                 | Transfer Size Register                                         | Table 13     |
| 0x1027           | TRANSFER_COUNT                | Transfer Count Register                                        | Section 9.13 |
| 0x1028           | SRC_TRANSFER_STEP             | Source Transfer Step Size Register                             | Section 9.14 |
| 0x1029           | DST_TRANSFER_STEP             | Destination Transfer Step Size Register                        | Section 9.15 |
| 0x102A           | SRC_WRAP_SIZE                 | Source Wrap Size Register                                      | Section 9.16 |
| 0x102B           | SRC_WRAP_COUNT                | Source Wrap Count Register                                     | Section 9.17 |
| 0x102C           | SRC_WRAP_STEP                 | Source Wrap Step Size Register                                 | Section 9.18 |
| 0x102D           | DST_WRAP_SIZE                 | Destination Wrap Size Register                                 | Section 9.16 |
| 0x102E           | DST_WRAP_COUNT                | Destination Wrap Count Register                                | Section 9.17 |
| 0x102F           | DST_WRAP_STEP                 | Destination Wrap Step Size Register                            | Section 9.18 |
| 0x1030           | SRC_BEG_ADDR_SHADOW           | Shadow Source Begin and Current Address Pointer Registers      | Section 9.19 |
| 0x1032           | SRC_ADDR_SHADOW               |                                                                | Section 9.19 |
| 0x1034           | SRC_BEG_ADDR                  | Active Source Begin and Current Address Pointer Registers      | Section 9.20 |
| 0x1036           | SRC_ADDR                      |                                                                | Section 9.20 |
| 0x1038           | DST_BEG_ADDR_SHADOW           | Shadow Destination Begin and Current Address Pointer Registers | Section 9.21 |
| 0x103A           | DST_ADDR_SHADOW               |                                                                | Section 9.21 |
| 0x103C           | DST_BEG_ADDR                  | Active Destination Begin and Current Address Pointer Registers | Section 9.22 |
| 0x103E           | DST_ADDR                      |                                                                | Section 9.22 |
| 0x103F           | Reserved                      | Reserved                                                       |              |
| DMA Chann        | nel 2 Registers               |                                                                |              |
| 0x1040<br>0x105F | Same as above                 |                                                                |              |
| DMA Chann        | nel 3 Registers               |                                                                |              |
| 0x1060<br>0x107F | Same as above                 |                                                                |              |
| DMA Chann        | nel 4 Registers               |                                                                |              |

<sup>(1)</sup> All DMA register writes are EALLOW protected.



### Table 2. DMA Register Summary (continued)

| Address          | Acronym        | Description | Section |
|------------------|----------------|-------------|---------|
| 0x1080<br>0x109F | Same as above  |             |         |
| DMA Chann        | el 5 Registers |             |         |
| 0x10A0<br>0x10BF | Same as above  |             |         |
| DMA Chann        | el 6 Registers |             |         |
| 0x10C0<br>0x10DF | Same as above  |             |         |

### 9.1 DMA Control Register (DMACTRL) — EALLOW Protected

The DMA control register (DMACTRL) is shown in Figure 8 and described in Table 3.

Figure 8. DMA Control Register (DMACTRL)



LEGEND: R0/S = Read 0/Set; R = Read only; -n = value after reset

### Table 3. DMA Control Register (DMACTRL) Field Descriptions

| Bit  | Field         | Value | Description                                                                                                                                                                                                                                                                                                                                                                                               |
|------|---------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-2 | Reserved      | 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1    | PRIORITYRESET | 0     | The priority reset bit resets the round-robin state machine when a 1 is written. Service starts from the first enabled channel. Writes of 0 are ignored and this bit always reads back a 0.                                                                                                                                                                                                               |
|      |               |       | When a 1 is written to this bit, any pending burst transfer completes before resetting the channel priority machine. If CH1 is configured as a high priority channel, and this bit is written to while CH1 is servicing a burst, the CH1 burst is completed and then any lower priority channel burst is also completed (if CH1 interrupted in the middle of a burst), before the state machine is reset. |
|      |               |       | In case CH1 is high priority, the <i>state machine</i> restarts from CH2 (or the next highest enabled channel).                                                                                                                                                                                                                                                                                           |
| 0    | HARDRESET     | 0     | Writing a 1 to the hard reset bit resets the whole DMA and aborts any current access (similar to applying a device reset). Writes of 0 are ignored and this bit always reads back a 0.                                                                                                                                                                                                                    |
|      |               |       | For a <i>soft</i> reset, a bit is provided for each channel to perform a gentler reset. Refer to the channel control registers.                                                                                                                                                                                                                                                                           |
|      |               |       | If the DMA was performing an access to the XINTF and the DMA access was stalled (XREADY not responding), then a HARDRESET would abort the access. The XINTF access would only complete if XREADY is released.                                                                                                                                                                                             |
|      |               |       | When writing to this bit, there is a one cycle delay before it takes effect. Hence at least a one cycle delay (i.e., a NOP instruction) after writing to this bit should be introduced before attempting an access to any other DMA register.                                                                                                                                                             |



### 9.2 Debug Control Register (DEBUGCTRL) — EALLOW Protected

The debug control register (DEBUGCTRL) is shown in Figure 9 and described in Table 4.

#### Figure 9. Debug Control Register (DEBUGCTRL)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 4. Debug Control Register (DEBUGCTRL) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                                               |
|------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | FREE     |       | Emulation Control Bit: This bit specifies the action when an emulation halt event occurs.                                                                                 |
|      |          | 0     | DMA runs until the current DMA read-write access is completed and the current status of a DMA is frozen. See the <i>HALT</i> points in Figure 5 for possible halt states. |
|      |          | 1     | DMA is unaffected by emulation suspend (run free)                                                                                                                         |
| 14-0 | Reserved | 0     | Reserved                                                                                                                                                                  |

### 9.3 Revision Register (REVISION)

The revision register (REVISION) is shown in Figure 10 and described in Table 5.

### Figure 10. Revision Register (REVISION)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 5. Revision Register (REVISION) Field Descriptions

| Bit  | Field | Value  | Description                                                                                                                                   |
|------|-------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8 | TYPE  |        | DMA Type Bits: These bits specify the DMA type and are changed if the functionality of the DMA is changed or any feature is added or removed. |
|      |       | 0x0000 | F2833x device type, 6 channels                                                                                                                |
| 7-0  | REV   |        | DMA Silicon Revision Bits: These bits specify the DMA revision and are changed if any bug fixes are performed.                                |
|      |       | 0x0000 | First release                                                                                                                                 |



### 9.4 Priority Control Register 1 (PRIORITYCTRL1) — EALLOW Protected

The priority control register 1 (PRIORITYCTRL1) is shown in Figure 11 and described in Table 6.

Figure 11. Priority Control Register 1 (PRIORITYCTRL1)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 6. Priority Control Register 1 (PRIORITYCTRL1) Field Descriptions

| Bit  | Field       | Value | Description                                                                                                                                                   |
|------|-------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-1 | Reserved    | 0     | Reserved                                                                                                                                                      |
| 0    | CH1PRIORITY |       | DMA Ch1 Priority: This bit selects whether channel 1 has higher priority or not:                                                                              |
|      |             | 0     | Same priority as all other channels                                                                                                                           |
|      |             | 1     | Highest priority channel                                                                                                                                      |
|      |             |       | Channel priority can only be changed when all channels are disabled. A priority reset should be performed before restarting channels after changing priority. |

### 9.5 Priority Status Register (PRIORITYSTAT)

The priority status register (PRIORITYSTAT) is shown in Figure 12 and described in Table 7.

Figure 12. Priority Status Register (PRIORITYSTAT)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 7. Priority Status Register (PRIORITYSTAT) Field Descriptions

| Bit  | Field                | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|----------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-7 | Reserved             | 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6-4  | ACTIVESTS_SH<br>ADOW |       | Active Channel Status Shadow Bits: These bits are only useful when CH1 is enabled as a higher priority channel. When CH1 is serviced, the ACTIVESTS bits are copied to the shadow bits and indicate which channel was interrupted by CH1. When CH1 service is completed, the shadow bits are copied back to the ACTIVESTS bits. If this bit field is zero or the same as the ACTIVESTS bit field, then no channel is pending due to a CH1 interrupt. When CH1 is not a higher priority channel, these bits should be ignored: |
|      |                      | 0,0,0 | No channel pending                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|      |                      | 0,0,1 | CH 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |                      | 0,1,0 | CH 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |                      | 0,1,1 | CH 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |                      | 1,0,0 | CH 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |                      | 1,0,1 | CH 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|      |                      | 1,1,0 | CH 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3    | Reserved             |       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



### Table 7. Priority Status Register (PRIORITYSTAT) Field Descriptions (continued)

| Bit | Field     | Value | Description                                                                                                                         |
|-----|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------|
| 2-0 | ACTIVESTS |       | Active Channel Status Bits: These bits indicate which channel is currently active or performing a transfer: 0,0,0 no channel active |
|     |           | 0,0,0 | CH 1                                                                                                                                |
|     |           | 0,1,0 | CH 2                                                                                                                                |
|     |           | 0,1,1 | CH 3                                                                                                                                |
|     |           | 1,0,0 | CH 4                                                                                                                                |
|     |           | 1,0,1 | CH 5                                                                                                                                |
|     |           | 1,1,0 | CH 6                                                                                                                                |



### 9.6 Mode Register (MODE) — EALLOW Protected

The mode register (MODE) is shown in Figure 13 and described in Table 8.

### Figure 13. Mode Register (MODE)

| 15      | 14       | 13      | 12        | 11         | 10      | 9         | 8       |
|---------|----------|---------|-----------|------------|---------|-----------|---------|
| CHINTE  | DATASIZE | SYNCSEL | SYNCE     | CONTINUOUS | ONESHOT | CHINTMODE | PERINTE |
| R/W-0   | R/W-0    | R/W-0   | R/W-0     | R/W-0      | R/W-0   | R/W-0     | R/W-0   |
| 7       | 6        | 5       | 4         |            |         |           | 0       |
| OVRINTE | Reserved |         | PERINTSEL |            |         |           |         |
| R/W-0   | R        | -0      |           |            | R/W-0   |           |         |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 8. Mode Register (MODE) Field Descriptions

| Bit | Field      | Value | Description                                                                                                                                                                                                                                                          |
|-----|------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | CHINTE     |       | Channel Interrupt Enable Bit: This bit enables/disables the respective DMA channel interrupt to the CPU (via the PIE).                                                                                                                                               |
|     |            | 0     | Interrupt disabled                                                                                                                                                                                                                                                   |
|     |            | 1     | Interrupt enabled                                                                                                                                                                                                                                                    |
| 14  | DATASIZE   |       | Data Size Mode Bit: This bit selects if the DMA channel transfers 16-bits or 32-bits of data at the time.                                                                                                                                                            |
|     |            | 0     | 16-bit data transfer size                                                                                                                                                                                                                                            |
|     |            | 1     | 32-bit data transfer size                                                                                                                                                                                                                                            |
|     |            |       | Note: It is up to you to configure the pointer step increment and size to accommodate 32-bit data transfers. See section Section 6 for details.                                                                                                                      |
| 13  | SYNCSEL    |       | Sync Mode Select Bit: This bit selects if the SRC or DST wrap counters are controlled by the sync function (if enabled by SYNCE bit).                                                                                                                                |
|     |            | 0     | SRC wrap counter controlled                                                                                                                                                                                                                                          |
|     |            | 1     | DST wrap counter controlled                                                                                                                                                                                                                                          |
| 12  | SYNCE      |       | Sync Enable Bit: If this bit is set to 1, the ADCSYNC signal is recognized if selected by the PERINTSEL bit field. This sync signal is used to synchronize ADC interrupt event triggers to the DMA wrap counter. If this bit is 0 then the ADCSYNC event is ignored. |
| 11  | CONTINUOUS |       | Continuous Mode Bit: If this bit is set to 1, then DMA re-initializes when TRANSFER_COUNT is zero and waits for the next interrupt event trigger. If this bit is 0, then the DMA stops and clears the RUNSTS bit to 0.                                               |
| 10  | ONESHOT    |       | One Shot Mode Bit: If this bit is set to 1, then subsequent burst transfers occur without additional event triggers after the first event trigger. If this bit is 0 then only one burst transfer is performed per event trigger.                                     |
| 9   | CHINTMODE  |       | Channel Interrupt Generation Mode Bit: This bit specifies when the respective DMA channel interrupt should be generated to the CPU (via the PIE).                                                                                                                    |
|     |            | 0     | Generate interrupt at beginning of new transfer                                                                                                                                                                                                                      |
|     |            | 1     | Generate interrupt at end of transfer.                                                                                                                                                                                                                               |
| 8   | PERINTE    |       | Peripheral Interrupt Trigger Enable Bit: This bit enables/disables the selected peripheral interrupt trigger to the DMA.                                                                                                                                             |
|     |            | 0     | Interrupt trigger disabled. Neither the selected peripheral nor software can start a DMA burst.                                                                                                                                                                      |
|     |            | 1     | Interrupt trigger enabled.                                                                                                                                                                                                                                           |



Table 8. Mode Register (MODE) Field Descriptions (continued)

| Bit                                              | Field    | Value                                                                                                                                                              | Description                                                                                                                                                                                                     |          |                                                      |
|--------------------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------------------------------------------------|
| 7                                                | OVRINTE  |                                                                                                                                                                    | Overflow Interrupt E when an overflow e                                                                                                                                                                         |          | en set to 1 enables the DMA to generate an interrupt |
|                                                  |          | 0                                                                                                                                                                  | Overflow interrupt of                                                                                                                                                                                           | lisabled |                                                      |
|                                                  |          | 1                                                                                                                                                                  | Overflow interrupt e                                                                                                                                                                                            | enabled  |                                                      |
|                                                  |          |                                                                                                                                                                    | An overflow interrupt is generated when the PERINTFLG is set and another interrupt event occurs. The PERINTFLG being set indicates a previous peripheral event is latched and has not been serviced by the DMA. |          |                                                      |
| 6-5                                              | Reserved | 0                                                                                                                                                                  | Reserved                                                                                                                                                                                                        |          |                                                      |
| for the given channel. Only one interrupt source |          | s: These bits select which interrupt triggers a DMA burst upt source can be selected. A DMA burst can also be bits also select whether the ADCSYNC signal connects |                                                                                                                                                                                                                 |          |                                                      |
|                                                  |          | Value                                                                                                                                                              | Interrupt                                                                                                                                                                                                       | Sync     | Peripheral                                           |
|                                                  |          | 0                                                                                                                                                                  | None                                                                                                                                                                                                            | None     | No Peripheral Connection                             |
|                                                  |          | 1                                                                                                                                                                  | SEQ1INT                                                                                                                                                                                                         | ADCSYNC  | ADC                                                  |
|                                                  |          | 2                                                                                                                                                                  | SEQ2INT                                                                                                                                                                                                         | None     |                                                      |
|                                                  |          | 3                                                                                                                                                                  | XINT1                                                                                                                                                                                                           | None     | External Interrupts                                  |
|                                                  |          | 4                                                                                                                                                                  | XINT2                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 5                                                                                                                                                                  | XINT3                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 6                                                                                                                                                                  | XINT4                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 7                                                                                                                                                                  | XINT5                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 8                                                                                                                                                                  | XINT6                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 9                                                                                                                                                                  | XINT7                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 10                                                                                                                                                                 | XINT13                                                                                                                                                                                                          | None     |                                                      |
|                                                  |          | 11                                                                                                                                                                 | TINT0                                                                                                                                                                                                           | None     | CPU Timers                                           |
|                                                  |          | 12                                                                                                                                                                 | TINT1                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 13                                                                                                                                                                 | TINT2                                                                                                                                                                                                           | None     |                                                      |
|                                                  |          | 14                                                                                                                                                                 | MXEVTA                                                                                                                                                                                                          | None     | McBSP-A                                              |
|                                                  |          | 15                                                                                                                                                                 | MREVTA                                                                                                                                                                                                          | None     |                                                      |
|                                                  |          | 16                                                                                                                                                                 | MXEVTB                                                                                                                                                                                                          | None     | McBSP-B                                              |
|                                                  |          | 17                                                                                                                                                                 | MREVTB                                                                                                                                                                                                          | None     |                                                      |
|                                                  |          | 31:18                                                                                                                                                              | Reserved                                                                                                                                                                                                        |          | No peripheral connection                             |

### 9.7 Control Register (CONTROL) — EALLOW Protected

The control register (CONTROL) is shown in Figure 14 and described in Table 9.

Figure 14. Control Register (CONTROL)

| 15       | 14      | 13      | 12        | 11              | 10        | 9       | 8         |
|----------|---------|---------|-----------|-----------------|-----------|---------|-----------|
| Reserved | OVRFLG  | RUNSTS  | BURSTSTS  | TRANSFERST<br>S | SYNCERR   | SYNCFLG | PERINTFLG |
| R-0      | R-0     | R-0     | R-0       | R-0             | R-0       | R-0     | R-0       |
| 7        | 6       | 5       | 4         | 3               | 2         | 1       | 0         |
| ERRCLR   | SYNCCLR | SYNCFRC | PERINTCLR | PERINTFRC       | SOFTRESET | HALT    | RUN       |
| R0/S-0   | R0/S-0  | R0/S-0  | R0/S-0    | R0/S-0          | R0/S-0    | R0/S-0  | R0/S-0    |

LEGEND: R0/S = Read 0/Set; R = Read only; -n = value after reset



### Table 9. Control Register (CONTROL) Field Descriptions

|     |             | 1     | ie 9. Control Register (CONTROL) Fleid Descriptions                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|-------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | Field       | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15  | Reserved    | 0     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14  | OVRFLG      |       | Overflow Flag Bit: This bit indicates if a peripheral interrupt event trigger is received from the selected peripheral and the PERINTFLG is already set.                                                                                                                                                                                                                                                                                     |
|     |             | 0     | No overflow event                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |             | 1     | Overflow event                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |             |       | The ERRCLR bit can be used to clear the state of this bit to 0. The OVRFLG bit is not affected by the PERINTFRC event.                                                                                                                                                                                                                                                                                                                       |
| 13  | RUNSTS      |       | Run Status Bit: This bit is set to 1 when the RUN bit is written to with a 1. This indicates the DMA channel is now ready to process peripheral interrupt event triggers. This bit is cleared to 0 when TRANSFER_COUNT reaches zero and CONTINUOUS mode bit is set to 0. This bit is also cleared to 0 when either the HARDRESET bit, the SOFTRESET bit, or the HALT bit is activated.                                                       |
|     |             | 0     | Chanel is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |             | 1     | Channel is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 12  | BURSTSTS    |       | Burst Status Bit: This bit is set to 1 when a DMA burst transfer begins and the BURST_COUNT is initialized with the BURST_SIZE. This bit is cleared to zero when BURST_COUNT reaches zero. This bit is also cleared to 0 when either the HARDRESET or the SOFTRESET bit is activated.                                                                                                                                                        |
|     |             | 0     | No burst activity                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |             | 1     | The DMA is currently servicing or suspending a burst transfer from this channel.                                                                                                                                                                                                                                                                                                                                                             |
| 11  | TRANSFERSTS |       | Transfer Status Bit: This bit is set to 1 when a DMA transfer begins and the address registers are copied to the shadow set and the TRANSFER_COUNT is initialized with the TRANSFER_SIZE. This bit is cleared to zero when TRANSFER_COUNT reaches zero. This bit is also cleared to 0 when either the HARDRESET or the SOFTRESET bit is activated.                                                                                           |
|     |             | 0     | No transfer activity                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |             | 1     | The channel is currently in the middle of a transfer regardless of whether a burst of data is actively being transferred or not.                                                                                                                                                                                                                                                                                                             |
| 10  | SYNCERR     |       | Sync ERR Bit: This bit indicates if an ADCSYNC event error has occurred. This bit is set to 1 when the ADCSYNC event occurs and the selected SRC or DST_WRAP_COUNT is not zero:                                                                                                                                                                                                                                                              |
|     |             | 0     | No sync error event                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |             | 1     | Sync error event                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |             |       | You should read the SYNCERR flag when servicing the respective DMA channel interrupt to determine if a sync error did occur.                                                                                                                                                                                                                                                                                                                 |
| 9   | SYNCFLG     |       | Sync Flag Bit: This bit indicates if an ADCSYNC event has occurred. This flag is automatically cleared when the first burst transfer begins.                                                                                                                                                                                                                                                                                                 |
|     |             | 0     | No sync event                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |             | 1     | Sync event                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |             |       | The SYNCFRC bit can be used to set the state of this bit to 1. The SYNCCLR bit can be used to clear the state of this bit to 0.                                                                                                                                                                                                                                                                                                              |
| 8   | PERINTFLG   |       | Peripheral Interrupt Trigger Flag Bit: This bit indicates if a peripheral interrupt event trigger has occurred. This flag is automatically cleared when the first burst transfer begins.                                                                                                                                                                                                                                                     |
|     |             | 0     | No interrupt event trigger                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |             | 1     | Interrupt event trigger                                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |             |       | The PERINTFRC bit can be used to set the state of this bit to 1 and force a software DMA event. The PERINTCLR bit can be used to clear the state of this bit to 0.                                                                                                                                                                                                                                                                           |
| 7   | ERRCLR      | 0     | Error Clear Bit: Writing a 1 to this bit will clear any latched sync error event and clear the SYNCERR bit. This bit will also clear the OVRFLG bit. This bit would normally be used when initializing the DMA for the first time or if an overflow condition is detected. If an ADCSYNC error event or overflow event occurs at the same time as writing to this bit, the ADC or overrun has priority and the SYNCERR or OVRFLG bit is set. |
| 6   | SYNCCLR     | 0     | Sync Clear Bit: Writing a 1 to this bit will clear a latched sync event and clear the SYNCFLG bit. This bit would normally be used when initializing the DMA for the first time. If an ADCSYNC event occurs at the same time as writing to this bit, the ADC has priority and the SYNCFLG bit is set.                                                                                                                                        |
| 5   | SYNCFRC     | 0     | Sync Force Bit: Writing a 1 to this bit latches a sync event and sets the SYNCFLG bit. This bit can be used like a software sync for the wrap counter.                                                                                                                                                                                                                                                                                       |



### Table 9. Control Register (CONTROL) Field Descriptions (continued)

| Bit | Field     | Value | Description                                                                                                                                                                                                                                                                                                                                       |
|-----|-----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | PERINTCLR | 0     | Peripheral Interrupt Clear Bit: Writing a 1 to this bit clears any latched peripheral interrupt event and clears the PERINTFLG bit. This bit would normally be used when initializing the DMA for the first time. If a peripheral event occurs at the same time as writing to this bit, the peripheral has priority and the PERINTFLG bit is set. |
| 3   | PERINTFRC | 0     | Peripheral Interrupt Force Bit: Writing a 1 to this bit latches a peripheral interrupt event trigger and sets the PERINTFLG bit. If the PERINTE bit is set, this bit can be used like a software force for a DMA burst transfer.                                                                                                                  |
| 2   | SOFTRESET | 0     | Channel Soft Reset Bit: Writing a 1 to this bit completes current read-write access and places the channel into a default state as follows:                                                                                                                                                                                                       |
|     |           |       | RUNSTS = 0                                                                                                                                                                                                                                                                                                                                        |
|     |           |       | TRANSFERSTS = 0                                                                                                                                                                                                                                                                                                                                   |
|     |           |       | BURSTSTS = 0                                                                                                                                                                                                                                                                                                                                      |
|     |           |       | BURST_COUNT = 0                                                                                                                                                                                                                                                                                                                                   |
|     |           |       | TRANSFER_COUNT = 0                                                                                                                                                                                                                                                                                                                                |
|     |           |       | SRC_WRAP_COUNT = 0                                                                                                                                                                                                                                                                                                                                |
|     |           |       | DST_WRAP_COUNT = 0                                                                                                                                                                                                                                                                                                                                |
|     |           |       | This is a <i>soft</i> reset that basically allows the DMA to complete the current read-write access and then places the DMA channel into the default reset state.                                                                                                                                                                                 |
| 1   | HALT      | 0     | Channel Halt Bit: Writing a 1 to this bit halts the DMA at the current state and any current read-write access is completed. See Figure 5 for the various positions the state machine can be at when HALTED. The RUNSTS bit is set to 0. To take the device out of HALT, the RUN bit needs to be activated.                                       |
| 0   | RUN       | 0     | Channel Run Bit: Writing a 1 to this bit starts the DMA channel. The RUNSTS bit is set to 1. This bit is also used to take the device out of HALT.                                                                                                                                                                                                |
|     |           |       | The RUN bit is typically used to start the DMA running after you have configured the DMA. It will then wait for the first interrupt event (PERINTFLG == 1) to start operation. The RUN bit can also be used to take the DMA channel out of a HALT condition See Figure 5 for the various positions the state machine can be at when HALTED.       |

### 9.8 Burst Size Register (BURST\_SIZE) — EALLOW Protected

The burst size register (BURST\_SIZE) is shown in Figure 15 and described in Table 10.

Figure 15. Burst Size Register (BURST\_SIZE)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 10. Burst Size Register (BURST\_SIZE) Field Descriptions

| Bit  | Field     | Value | Description                                |  |
|------|-----------|-------|--------------------------------------------|--|
| 15-5 | Reserved  | 0     | Reserved                                   |  |
| 4-0  | BURSTSIZE |       | hese bits specify the burst transfer size: |  |
|      |           | 0     | Transfer 1 word in a burst                 |  |
|      |           | 1     | Transfer 2 words in a burst                |  |
|      |           |       |                                            |  |
|      |           | 31    | Transfer 32 words in a burst               |  |



### 9.9 BURST\_COUNT Register

The burst count register (BURST\_COUNT) is shown in Figure 16 and described in Table 11.

Figure 16. Burst Count Register (BURST\_COUNT)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 11. Burst Count Register (BURST\_COUNT) Field Descriptions

| Bit  | Field      | Value | Description                                                                 |
|------|------------|-------|-----------------------------------------------------------------------------|
| 15-5 | Reserved   | 0     | Reserved                                                                    |
| 4-0  | BURSTCOUNT |       | These bits indicate the current burst counter value:                        |
|      |            | 0     | 0 word left in a burst                                                      |
|      |            | 1     | 1 word left in a burst                                                      |
|      |            | 2     | 2 words left in a burst                                                     |
|      |            |       |                                                                             |
|      |            | 31    | 31 words left in a burst                                                    |
|      |            |       | The above values represent the state of the counter at the HALT conditions. |

### 9.10 Source Burst Step Register Size (SRC\_BURST\_STEP) — EALLOW Protected

The source burst step size register (SRC\_BURST\_STEP) is shown in Figure 17 and described in Table 12.

Figure 17. Source Burst Step Size Register (SRC\_BURST\_STEP)

15 0
SRCBURSTSTEP
RW-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 12. Source Burst Step Size Register (SRC\_BURST\_STEP) Field Descriptions

| Bit  | Field        | Value  | Description                                                                                                |
|------|--------------|--------|------------------------------------------------------------------------------------------------------------|
| 15-0 | SRCBURSTSTEP |        | These bits specify the source address post-increment/decrement step size while processing a burst of data: |
|      |              | 0x0FFF | Add 4095 to address                                                                                        |
|      |              |        |                                                                                                            |
|      |              | 0x0002 | Add 2 to address                                                                                           |
|      |              | 0x0001 | Add 1 to address                                                                                           |
|      |              | 0x0000 | No address change                                                                                          |
|      |              | 0xFFFF | Sub 1 from address                                                                                         |
|      |              | 0xFFFE | Sub 2 from address                                                                                         |
|      |              |        |                                                                                                            |
|      |              | 0xF000 | Sub 4096 from address                                                                                      |
|      |              |        | Only values from -4096 to 4095 are valid.                                                                  |



### 9.11 Destination Burst Step Register Size (DST\_BURST\_STEP) — EALLOW Protected

The destination burst step register size (DST\_BURST\_STEP) is shown in Figure 18 and described in Table 13.

Figure 18. Destination Burst Step Register Size (DST\_BURST\_STEP)

15 0
DSTBURSTSTEP

R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 13. Destination Burst Step Register Size (DST\_BURST\_STEP) Field Descriptions

| Bit  | Field        | Value  | Description                                                                                                     |
|------|--------------|--------|-----------------------------------------------------------------------------------------------------------------|
| 15-0 | DSTBURSTSTEP |        | These bits specify the destination address post-increment/decrement step size while processing a burst of data: |
|      |              | 0x0FFF | Add 4095 to address                                                                                             |
|      |              |        |                                                                                                                 |
|      |              | 0x0002 | Add 2 to address                                                                                                |
|      |              | 0x0001 | Add 1 to address                                                                                                |
|      |              | 0x0000 | No address change                                                                                               |
|      |              | 0xFFFF | Sub 1 from address                                                                                              |
|      |              | 0xFFFE | Sub 2 from address                                                                                              |
|      |              |        |                                                                                                                 |
|      |              | 0xF000 | Sub 4096 from address                                                                                           |
|      |              |        | Only values from -4096 to 4095 are valid.                                                                       |

### 9.12 Transfer Size Register (TRANSFER\_SIZE) — EALLOW Protected

The transfer size register (TRANSFER\_SIZE) is shown in Figure 19 and described in Table 14.

Figure 19. Transfer Size Register (TRANSFER\_SIZE)

15 0
TRANSFERSIZE

R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 14. Transfer Size Register (TRANSFER\_SIZE) Field Descriptions

| Bit  | Field        | Value  | Description                                          |
|------|--------------|--------|------------------------------------------------------|
| 15-0 | TRANSFERSIZE |        | These bits specify the number of bursts to transfer: |
|      |              | 0x0000 | Transfer 1 burst                                     |
|      |              | 0x0001 | Transfer 2 bursts                                    |
|      |              | 0x0002 | Transfer 3 bursts                                    |
|      |              |        |                                                      |
|      |              | 0xFFFF | Transfer 65536 bursts                                |



### 9.13 Transfer Count Register (TRANSFER\_COUNT)

The transfer count register (TRANSFER\_COUNT) is shown in Figure 20 and described in Table 15.

### Figure 20. Transfer Count Register (TRANSFER\_COUNT)

15 0

TRANSFERCOUNT

R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 15. Transfer Count Register (TRANSFER\_COUNT) Field Descriptions

| Bit  | Field         | Value  | Description                                                                 |
|------|---------------|--------|-----------------------------------------------------------------------------|
| 15-0 | TRANSFERCOUNT |        | These bits specify the current transfer counter value:                      |
|      |               | 0x0000 | 0 bursts left to transfer                                                   |
|      |               | 0x0001 | 1 burst left to transfer                                                    |
|      |               | 0x0002 | 2 bursts left to transfer                                                   |
|      |               |        |                                                                             |
|      |               | 0xFFFF | 65535 bursts left to transfer                                               |
|      |               |        | The above values represent the state of the counter at the HALT conditions. |

### 9.14 Source Transfer Step Size Register (SRC\_TRANSFER\_STEP) — EALLOW Protected

The source transfer step size register (SRC\_TRANSFER\_STEP) is shown in Figure 21 and described in Table 16.

Figure 21. Source Transfer Step Size Register (SRC\_TRANSFER\_STEP)

15 SRCTRANSFERSTEP 0

R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 16. Source Transfer Step Size Register (SRC\_TRANSFER\_STEP) Field Descriptions

| Bit  | Field           | Value  | Description                                                                                                        |
|------|-----------------|--------|--------------------------------------------------------------------------------------------------------------------|
| 15-0 | SRCTRANSFERSTEP |        | These bits specify the source address pointer post-increment/decrement step size after processing a burst of data: |
|      |                 | 0x0FFF | Add 4095 to address                                                                                                |
|      |                 |        |                                                                                                                    |
|      |                 | 0x0002 | Add 2 to address                                                                                                   |
|      |                 | 0x0001 | Add 1 to address                                                                                                   |
|      |                 | 0x0000 | No address change                                                                                                  |
|      |                 | 0xFFFF | Sub 1 from address                                                                                                 |
|      |                 | 0xFFFE | Sub 2 from address                                                                                                 |
|      |                 |        |                                                                                                                    |
|      |                 | 0xF000 | Sub 4096 from address                                                                                              |
|      |                 |        | Only values from -4096 to 4095 are valid.                                                                          |



### 9.15 Destination Transfer Step Size Register (DST\_TRANSFER\_STEP) — EALLOW Protected

The destination transfer step size register (DST\_TRANSFER\_STEP) is shown in Figure 22 and described in Table 17.

Figure 22. Destination Transfer Step Size Register (DST\_TRANSFER\_STEP)

15 0

DSTTRANSFERSTEP

R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 17. Destination Transfer Step Size Register (DST\_TRANSFER\_STEP) Field Descriptions

| Bit  | Field           | Value  | Description                                                                                                             |
|------|-----------------|--------|-------------------------------------------------------------------------------------------------------------------------|
| 15-0 | DSTTRANSFERSTEP |        | These bits specify the destination address pointer post-increment/decrement step size after processing a burst of data: |
|      |                 | 0x0FFF | Add 4095 to address                                                                                                     |
|      |                 |        |                                                                                                                         |
|      |                 | 0x0002 | Add 2 to address                                                                                                        |
|      |                 | 0x0001 | Add 1 to address                                                                                                        |
|      |                 | 0x0000 | No address change                                                                                                       |
|      |                 | 0xFFFF | Sub 1 from address                                                                                                      |
|      |                 | 0xFFFE | Sub 2 from address                                                                                                      |
|      |                 |        |                                                                                                                         |
|      |                 | 0xF000 | Sub 4096 from address                                                                                                   |
|      |                 |        | Only values from -4096 to 4095 are valid.                                                                               |

### 9.16 Source/Destination Wrap Size Register (SRC/DST\_WRAP\_SIZE) — EALLOW protected)

The source/destination wrap size register is shown in Figure 23 and described in Table 18.

Figure 23. Source/Destination Wrap Size Register (SRC/DST\_WRAP\_SIZE)

15 0 WRAPSIZE R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

Table 18. Source/Destination Wrap Size Register (SRC/DST\_WRAP\_SIZE) Field Descriptions

| Bit  | Field    | Value  | Description                                                                                                  |  |
|------|----------|--------|--------------------------------------------------------------------------------------------------------------|--|
| 15-0 | WRAPSIZE |        | These bits specify the number of bursts to transfer before wrapping back to begin address pointer:           |  |
|      |          | 0x0000 | Wrap after 1 burst                                                                                           |  |
|      |          | 0x0001 | Wrap after 2 bursts                                                                                          |  |
|      |          | 0x0002 | Wrap after 3 bursts                                                                                          |  |
|      |          |        |                                                                                                              |  |
|      |          | 0xFFFF | Wrap after 65536 bursts                                                                                      |  |
|      |          |        | To disable the wrap function, set the WRAPSIZE bit field to a number larger that the TRANSFERSIZE bit field. |  |



### 9.17 Source/Destination Wrap Count Register (SCR/DST\_WRAP\_COUNT)

The source/destination wrap count register (SCR/DST\_WRAP\_COUNT) is shown in Figure 24 and described in Table 19.

Figure 24. Source/Destination Wrap Count Register (SCR/DST\_WRAP\_COUNT)

15 0
WRAPCOUNT
R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

### Table 19. Source/Destination Wrap Count Register (SCR/DST\_WRAP\_COUNT) Field Descriptions

| Bit  | Field     | Value                                               | Description                                                                 |  |
|------|-----------|-----------------------------------------------------|-----------------------------------------------------------------------------|--|
| 15-0 | WRAPCOUNT | These bits indicate the current wrap counter value: |                                                                             |  |
|      |           | 0x0000                                              | 0x0000 Wrap complete                                                        |  |
|      |           | 0x0001 1 burst left                                 |                                                                             |  |
|      |           | 0x0002 2 burst left                                 |                                                                             |  |
|      |           |                                                     |                                                                             |  |
|      |           | 0xFFFF                                              | F 65535 burst left                                                          |  |
|      |           |                                                     | The above values represent the state of the counter at the HALT conditions. |  |

# 9.18 Source/Destination Wrap Step Size Registers (SRC/DST\_WRAP\_STEP) — EALLOW Protected

The source/destination wrap step size register (SRC/DST\_WRAP\_STEP) are shown in Figure 25 and described in Table 20.

Figure 25. Source/Destination Wrap Step Size Registers (SRC/DST\_WRAP\_STEP)

15 0 WRAPSTEP R/W-0

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 20. Source/Destination Wrap Step Size Registers (SRC/DST WRAP STEP) Field Descriptions

| Bit  | Field    | Value  | Description                                                                                                        |
|------|----------|--------|--------------------------------------------------------------------------------------------------------------------|
| 15-0 | WRAPSTEP |        | These bits specify the source begin address pointer post-increment/decrement step size after wrap counter expires: |
|      |          | 0x0FFF | Add 4095 to address                                                                                                |
|      |          |        |                                                                                                                    |
|      |          | 0x0002 | Add 2 to address                                                                                                   |
|      |          | 0x0001 | Add 1 to address                                                                                                   |
|      |          | 0x0000 | No address change                                                                                                  |
|      |          | 0xFFFF | Sub 1 from address                                                                                                 |
|      |          | 0xFFFE | Sub 2 from address                                                                                                 |
|      |          |        |                                                                                                                    |
|      |          | 0xF000 | Sub 4096 from address                                                                                              |
|      |          |        | Only values from -4096 to 4095 are valid.                                                                          |



# 9.19 Shadow Source Begin and Current Address Pointer Registers (SRC\_BEG\_ADDR\_SHADOW/DST\_BEG\_ADDR\_SHADOW) — All EALLOW Protected

The shadow source begin and current address pointer registers (SRC\_BEG\_ADDR\_SHADOW/DST\_BEG\_ADDR\_SHADOW) are shown in Figure 26 and described in Table 21.

# Figure 26. Shadow Source Begin and Current Address Pointer Registers (SRC\_BEG\_ADDR\_SHADOW/DST\_BEG\_ADDR\_SHADOW)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 21. Shadow Source Begin and Current Address Pointer Registers (SRC BEG ADDR SHADOW/DST BEG ADDR SHADOW) Field Descriptions

| Bit   | Field    | Value | Description          |
|-------|----------|-------|----------------------|
| 31-22 | Reserved | 0     | Reserved             |
| 21-0  | BEGADDR  |       | 22-bit address value |

# 9.20 Active Source Begin and Current Address Pointer Registers (SRC BEG ADDR/DST BEG ADDR)

The active source begin and current address pointer registers (SRC\_BEG\_ADDR/DST\_BEG\_ADDR) are shown in Table 22 and described in Table 22.

# Figure 27. Active Source Begin and Current Address Pointer Registers (SRC\_BEG\_ADDR/DST\_BEG\_ADDR)

| 31 22    | 21 0    |
|----------|---------|
| Reserved | BEGADDR |
| R-0      | R-0     |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 22. Active Source Begin and Current Address Pointer Registers (SRC\_BEG\_ADDR/DST\_BEG\_ADDR) Field Descriptions

| Bit   | Field    | Value | Description          |
|-------|----------|-------|----------------------|
| 31-22 | Reserved | 0     | Reserved             |
| 21-0  | BEGADDR  |       | 22-bit address value |



# 9.21 Shadow Destination Begin and Current Address Pointer Registers (SRC\_ADDR\_SHADOW/DST\_ADDR\_SHADOW) — All EALLOW Protected

The shadow destination begin and current address pointer registers (SRC\_ADDR\_SHADOW/DST\_ADDR\_SHADOW) are shown in Figure 28 and described in Table 23.

# Figure 28. Shadow Destination Begin and Current Address Pointer Registers (SRC ADDR SHADOW/DST ADDR SHADOW)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 23. Shadow Destination Begin and Current Address Pointer Registers (SRC\_ADDR\_SHADOW/DST\_ADDR\_SHADOW) Field Descriptions

| Bit   | Field    | Value | Description          |  |
|-------|----------|-------|----------------------|--|
| 31-22 | Reserved | 0     | Reserved             |  |
| 21-0  | ADDR     |       | 22-bit address value |  |

### 9.22 Active Destination Begin and Current Address Pointer Registers (SRC\_ADDR/DST\_ADDR)

The active destination begin and current address pointer registers (SRC\_ADDR/DST\_ADDR) are shown in Figure 29 and described in Table 24.

# Figure 29. Active Destination Begin and Current Address Pointer Registers (SRC\_ADDR/DST\_ADDR)



LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

# Table 24. Active Destination Begin and Current Address Pointer Registers (SRC\_ADDR/DST\_ADDR) Field Descriptions

| Bit   | Field    | Value | Description          |
|-------|----------|-------|----------------------|
| 31-22 | Reserved | 0     | Reserved             |
| 21-0  | ADDR     |       | 22-bit address value |

#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

TI warrants performance of its hardware products to the specifications applicable at the time of sale in accordance with TI's standard warranty. Testing and other quality control techniques are used to the extent TI deems necessary to support this warranty. Except where mandated by government requirements, testing of all parameters of each product is not necessarily performed.

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

| Products              |                        | Applications       |                           |
|-----------------------|------------------------|--------------------|---------------------------|
| Amplifiers            | amplifier.ti.com       | Audio              | www.ti.com/audio          |
| Data Converters       | dataconverter.ti.com   | Automotive         | www.ti.com/automotive     |
| DSP                   | dsp.ti.com             | Broadband          | www.ti.com/broadband      |
| Interface             | interface.ti.com       | Digital Control    | www.ti.com/digitalcontrol |
| Logic                 | logic.ti.com           | Military           | www.ti.com/military       |
| Power Mgmt            | power.ti.com           | Optical Networking | www.ti.com/opticalnetwork |
| Microcontrollers      | microcontroller.ti.com | Security           | www.ti.com/security       |
| RFID                  | www.ti-rfid.com        | Telephony          | www.ti.com/telephony      |
| Low Power<br>Wireless | www.ti.com/lpw         | Video & Imaging    | www.ti.com/video          |
|                       |                        | Wireless           | www.ti.com/wireless       |

Mailing Address: Texas Instruments, Post Office Box 655303, Dallas, Texas 75265 Copyright © 2007, Texas Instruments Incorporated